草庐IT

php - FedEx express 汇率 API 请求

全部标签

ruby-on-rails - 如何将特定请求详细信息记录到 Rails 服务器日志

我通常不喜欢在不了解正在发生的事情的情况下直接询问如何做某事,但我对Rails还很陌生,我很难做到这一点。基本上,我需要在单个日志语句中为每个请求捕获以下信息(如果可能的话)日志条目日期日志录入时间HTTP方法请求的URL港口请求者IP地址请求者的用户代理引用网址HTTP响应码主机名自定义日志格式的首选方式是什么?是否可以只修改现有日志并将此信息传递给它?或者我是否需要扩展和覆盖我需要的行为?我不需要将其保存到不同的日志文件或任何其他文件中,只需在每次请求时输出到STDOUT。如有任何帮助,我们将不胜感激。谢谢! 最佳答案 我知道这

ruby - 异步发出多个 HTTP 请求

require'net/http'urls=[{'link'=>'http://www.google.com/'},{'link'=>'http://www.yandex.ru/'},{'link'=>'http://www.baidu.com/'}]urls.eachdo|u|u['content']=Net::HTTP.get(URI.parse(u['link']))endprinturls此代码以同步方式工作。第一个请求,第二个,第三个。我想异步发送所有请求并在所有请求完成后打印urls。最好的方法是什么?Fiber适合吗? 最佳答案

ruby-on-rails - 在 Ruby 中发送 HTTP/2 POST 请求

我正在尝试使用新的ApplePushNotificationAPI,基于HTTP/2.我找到了http-2Rubygem,但文档并不清楚如何作为客户端发出请求。如何在Ruby/Rails中发出HTTP/2请求? 最佳答案 免责声明:我是下面列出的两个gem的作者。如果你想发出HTTP/2调用,你可以考虑NetHttp2,Ruby的HTTP/2客户端。同步调用的使用示例:require'net-http2'#createaclientclient=NetHttp2::Client.new("http://106.186.112.116

ruby - 有没有办法将 Ruby Net::HTTP 请求附加到特定的 IP 地址/网络接口(interface)?

我正在寻找一种使用标准Net::HTTP库为每个GET请求使用不同IP地址的方法。服务器有5个IP地址,并假设某些API在达到每个IP的请求限制时阻止访问。所以,唯一的办法就是使用另一台服务器。我在ruby​​文档中找不到任何关于它的信息。例如,curl允许您将其附加到特定的ip地址(在PHP中):$req=curl_init($url)curl_setopt($req,CURLOPT_INTERFACE,'ip.address.goes.here';$result=curl_exec($req);有什么方法可以用Net::HTTP库来实现吗?作为替代方案-CURB(rubycurl绑

ruby-on-rails - 如何使用 Ruby MiniTest::Spec 和 Rails 进行 API 集成测试?

我正在构建一个包含RailsAPI的应用程序,并希望使用RubyMiniTest::Spec进行测试。设置它的好方法是什么?例如,良好的目录组织、包含文件的好方法等?我正在使用Rails3InAction一书中的指南,该书使用RSpec并且有一个关于API的重要章节。最大的变化是更喜欢MiniTest::Spec。 最佳答案 用我目前发现的内容来回答,以防对其他开发人员有帮助....规范/api/items_spec.rbrequire'spec_helper'classItemsSpec规范/spec_helper.rbENV["

ruby - Sinatra 请求 ["SOME_HEADER"] 不适用于 POST;文档错误?

Sinatra自述文件says:request["SOME_HEADER"]#valueofSOME_HEADERheader鉴于此应用:require'sinatra'post'/env'doenv['HTTP_X_FOO']endpost'/request'dorequest['X-Foo']endpost'/request_rack_http_format'dorequest['HTTP_X_FOO']end第一个规范通过;接下来的两个失败:describe"Sinatrashouldplacetheheaderin"dobefore(:all)doheader'X-Foo','

ruby - 将所有客户从 Stripe API 检索到一个列表中的最佳做法是什么

当调用Stripe::Customer.all(:limit=>100)时,每次调用有100个限制。我们的客户比这多得多,我想一下子把他们全部搞定。我是否遗漏了什么,或者这是否只能通过编写一个简单的循环来检查has_more属性然后进行新调用直到has_more=false才能实现? 最佳答案 你是对的,你必须写一个带有游标的简单循环perthestripedocs:starting_afteroptionalAcursorforuseinpagination.starting_afterisanobjectIDthatdefine

php - Ruby 和 PHP HMAC 不一致

我尝试在Ruby中创建一个HMAC,然后在PHP中验证它。ruby:require'openssl'message="A522EBF2-5083-484D-99D9-AA97CE49FC6C,1234567890,/api/comic/aWh62,GET"key="3D2143BD-6F86-449F-992C-65ADC97B968B"hash=OpenSSL::HMAC.hexdigest('sha256',message,key)phashPHP:对于Ruby,我得到:20e3f261b762e8371decdf6f42a5892b530254e666508e885c708c5b

ruby-on-rails - Ruby VCR gem 不断记录相同的请求

在我的cucumber支持目录中,我在vcr.rb中有以下内容:require'vcr'VCR.configuredo|c|c.cassette_library_dir='fixtures/vcr_cassettes'c.hook_into:webmockc.ignore_localhost=truec.default_cassette_options={record::new_episodes}end我正在对调用GoogleMapsAPI的城市名称进行地理编码。我正在尝试记录并stub这些请求,但它一直将相同的请求记录到同一个yml文件:-request:method:geturi:

php - Facebook 扼杀了公共(public) RSS 提要;如何获取带有新时间线的 Facebook 页面 RSS?

我正在尝试从Facebook提取一个页面提要到RSS,但是每次我尝试尝试时,我都会在XML中返回一个错误,内容如下:">https://www.facebook.com/profile.php?id=</a>]]>我使用的网址是:https://www.facebook.com/feeds/page.php?id=&format=rss20&access_token=我没有设置年龄限制,也没有国家/地区限制:此外,我已经尝试过使用和不使用访问token。如以下评论所述,JSONURL确实有效:https://graph.facebook.com//feed&